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DETAILED ACTION 

1 . Claims 1-25, as amended on 9/29/2008, are pending in the instant application. 
Applicant's arguments submitted 9/29/2008 have been carefully considered, but are not 
found fully persuasive. 

Continued Examination Under 37 CFR 1.114 

2. A request for continued examination under 37 CFR 1.114, including the fee set 
forth in 37 CFR 1.17(e), was filed in this application after final rejection. Since this 
application is eligible for continued examination under 37 CFR 1.114, and the fee set 
forth in 37 CFR 1 .17(e) has been timely paid, the finality of the previous Office action 
has been withdrawn pursuant to 37 CFR 1.114. Applicant's submission filed on 
9/29/2008 has been entered. 

Claim Objections 

3. Claim 22 is objected to because of the following informalities: Claim 22, line 2 
recites "to recover form an error". The Examiner respectfully submits that 'form' should 
be changed to 'from'. Appropriate correction is required. 

Claim Rejections - 35 USC § 102 

4. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 1 02 that 
form the basis for the rejections under this section made in this Office action: 

A person shall be entitled to a patent unless - 
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(b) the invention was patented or described in a printed publication in this or a foreign country or in public 
use or on sale in this country, more than one year prior to the date of application for patent in the United 
States. 

5. Claims 1-4, 11-14, and 18- 21 are rejected under 35 U.S.C. 102(b) as being 
anticipated by Conley (US 2002/0099904). 



6. Claim 1 is taught by Conley as: 

a. A flash memory access apparatus, comprising: a flash memory comprising 
a plurality of units, each of the units comprising a plurality of blocks, and a flash 
memory controller. Paragraph 0038 teaches the architecture of a typical non- 
volatile data storage system, which includes a controller and a plurality of flash 
memory devices. Paragraph 0040 explains that flash memory cells are divided 
into multiple pages. 

b. Wherein if a write operation is requested for a logical block number of the 
flash memory, the flash memory controller is configured to write data and meta- 
information comprising flash memory state information comprising an indicator 
which indicates a state of the physical block as valid, deleted, or invalid in the 
physical block corresponding to a logical block with the logical block number if a 
previous write operation has not been performed for the logical block. Paragraph 
0062 discusses a method of programming a non-volatile memory. If there are 
pages in the physical block that have not been written to, the data is written to 
those blocks. Paragraph 0055 shows a page contains a time stamp 43. 
Paragraph 0050 shows that the time stamp indicates the time the page was 
written relative to other pages with the same logical address. As shown in 
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paragraph 0052, the time stamps of blocks having the same logical block 
address and page offset are compared, which allows the system to determine 
which page is the last written page. Accordingly, this shows what pages are valid 
and which pages are invalid. Additionally, when the block is erased, the 
timestamp field will contain all 1's, indicating that the block is deleted, 
c. And the flash memory controller is configured to perform a write operation 
for writing the data and the meta-information, comprising writing the valid 
indicator, allocated to the logical block in a new physical block without changing 
flash memory state information, wherein the flash memory state information is 
written in a previous physical block corresponding to the logical block if the 
previous write operation has been performed for the logical block. Paragraph 
0049 shows that when new data is to be written to a logical block corresponding 
to physical block PBN 0, item 35 of figure 8, which is full, a new physical block 
PBN 1 , item 39 of figure 8, is selected and the new pages are written to PBN 1 . 
Figure 8 also shows that original block PBN0 contains timestamps 43 and LBN 
and page tag 41 for each page in the original block. Paragraph 0055 shows that 
an individual page contains data, item 45 of figure 10, and meta-information, item 
49 of figure 10. Paragraph 0048 shows that when new pages are written to a 
logical block, the pages containing the original data are not tagged. The last 
sentence of paragraph 0047 further emphasizes this by stating "the writing of the 
old/new or other flags, as described with respect to FIGS. 6, 7 A and 7B, cannot 
be tolerated." 
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d. And wherein the flash memory state information is time independent. 
Paragraph 0051 shows that the output of a modulo-N counter can be used to 
generate the value of field 43, which is shown in paragraph 0052 to be used to 
determine if a block is the most recent block. 

7. Claim 2 is taught by Conley as: 

e. The apparatus as claimed in claim 1, wherein each physical block 
comprises: a first area, into which the data is written, and a second area, into 
which meta-information is written. Figure 10 shows that a page includes user 
data area 45 and overhead area 49. 

8. Claim 3 is taught by Conley as: 

f . The apparatus as claimed in claim 1, wherein data and meta-information 
of the logical block are simultaneously written. Paragraph 0055 shows that the 
data 45 and meta-information 49 are part of the same page. As the data and 
meta-information are part of the same page they would inherently be written 
simultaneously, as the system of Conley writes data on a page basis. 

9. Claim 4 is taught by Conley as: 

g. The apparatus as claimed in claim 1, wherein the meta-information further 
comprises the logical block number. Paragraph 0055 shows that overhead data, 
item 49 of figure 10, contains the logical block number. 
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h. And the flash memory state information indicating a state of the physical 
block as valid, deleted, or invalid. Paragraph 0055 shows a page contains a 
time stamp 43, paragraph 0051 shows that the timestamp can be replaced with 
the output of a modulo-N counter. Paragraph 0050 shows that the time stamp 
indicates the time the page was written relative to other pages with the same 
logical address. As shown in paragraph 0052, the time stamps of blocks having 
the same logical block address and page offset are compared, which allows the 
system to determine which page is the last written page. Accordingly, this shows 
what pages are valid. 



1 0. Claim 1 1 is taught by Conley as: 

i. A flash memory access method, comprising: accessing the flash memory 
and searching for a currently writable physical block if a processor requests a 
write operation for a specific logical block number of the flash memory. 
Paragraph 0062 shows that when a write is performed, an available physical 
page is found. 

j. And writing data and meta-information, comprising flash memory state 
information comprising an indicator which indicates a state of the physical block 
as valid, deleted, or invalid, in the physical block corresponding to a logical block 
with the logical block number if a previous write operation has not been 
performed for the logical block. Paragraph 0062 discusses a method of 
programming a non-volatile memory. If there are pages in the physical block that 
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have not been written to, the data is written to those blocks. Paragraph 0055 
shows a page contains a time stamp 43. Paragraph 0050 shows that the time 
stamp indicates the time the page was written relative to other pages with the 
same logical address. As shown in paragraph 0052, the time stamps of blocks 
having the same logical block address and page offset are compared, which 
allows the system to determine which page is the last written page. Accordingly, 
this shows what pages are valid and which pages are invalid. Additionally, when 
the block is erased, the timestamp field will contain all 1's, indicating that the 
block is deleted. 

k. And writing the data and the meta-information comprising writing the valid 
indicator in a new physical block corresponding to the logical block without 
changing flash memory state information, wherein the flash memory state 
information is written in a previous physical block corresponding to the logical 
block if the previous write operation has been performed for the logical block. 
Paragraph 0049 shows that when new data is to be written to a logical block 
corresponding to physical block PBN 0, item 35 of figure 8, which is full, a new 
physical block PBN 1 , item 39 of figure 8, is selected and the new pages are 
written to PBN 1 . Figure 8 also shows that original block PBN0 contains 
timestamps 43 and LBN and page tag 41 for each page in the original block. 
Paragraph 0055 shows that an individual page contains data, item 45 of figure 
10, and meta-information, item 49 of figure 10. Paragraph 0048 shows that when 
new pages are written to a logical block, the pages containing the original data 
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are not tagged. The last sentence of paragraph 0047 further emphasizes this by 
stating "the writing of the old/new or other flags, as described with respect to 
FIGS. 6, 7 A and 7B, cannot be tolerated." 

I. Wherein the flash memory state information is time independent. 
Paragraph 0051 shows that the output of a modulo-N counter can be used to 
generate the value of field 43, which is shown in paragraph 0052 to be used to 
determine if a block is the most recent block. 

11. Claim 12 is taught by Conley as: 

m. The method as claimed in claim 1 1, wherein each physical block 
comprises first and second areas, the method further comprising: writing data 
into the first area, and writing the meta-information into the second area. Figure 
10 shows that a page includes user data area 45 and overhead area 49, and 
paragraph 0055 shows that the corresponding data is written to each area. 

12. Claim 13 is taught by Conley as: 

n. The apparatus as claimed in claim 1 1, wherein the data and meta- 
information of the logical block are simultaneously written. Paragraph 0055 
shows that the data 45 and meta-information 49 are part of the same page. As 
the data and meta-information are part of the same page they would inherently 
be written simultaneously, as the system of Conley writes data on a page basis. 
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1 3. Claim 14 is taught by Conley as: 

o. The method as claimed in claim 11, wherein the meta-information 
comprises the logical block number. Paragraph 0055 shows that overhead data, 
item 49 of figure 10, contains the logical block number, 
p. And the flash memory state information indicating a state of the physical 
block as valid, deleted, or invalid. Paragraph 0055 shows a page contains a 
time stamp, paragraph 0051 shows that the timestamp can be replaced with the 
output of a modulo-N counter. Paragraph 0050 shows that the time stamp 
indicates the time the page was written relative to other pages with the same 
logical address. As shown in paragraph 0052, the time stamps of blocks having 
the same logical block address and page offset are compared, which allows the 
system to determine which page is the last written page. Accordingly, this shows 
what pages are valid. 

14. Claim 18 is taught by Conley as: 

q. A flash memory access apparatus, comprising: a flash memory comprising 
a plurality of physical blocks. Paragraph 0038 teaches the architecture of a 
typical non-volatile data storage system, which includes a controller and a 
plurality of flash memory devices. Paragraph 0040 explains that flash memory 
cells are divided into multiple pages. 

r. Wherein each physical block of the plurality of physical blocks comprises 
data and meta-information, and the meta-information comprises a logical block 
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number and flash memory state information. Paragraph 0055 shows that each 
page contains an overhead data area 49, which includes the LBN and page tag 
41 and time stamp 43, which is used to determine if the stored data is the valid 
data for the corresponding logical page. Figure 8 shows that original block PBN0 
contains timestamp 43 and LBN and page tag 41 for each page in the original 
block. 

s. Wherein the flash memory state information is time independent and 
comprises an indicator which indicates a state of the physical block as valid, 
deleted, or invalid. Paragraph 0051 shows that instead of a timestamp, a 
modulo-N counter may be used which is incremented each time a logical block is 
updated. Paragraph 0055 shows a page contains a time stamp 43. Paragraph 
0050 shows that the time stamp indicates the time the page was written relative 
to other pages with the same logical address. As shown in paragraph 0052, the 
time stamps of blocks having the same logical block address and page offset are 
compared, which allows the system to determine which page is the last written 
page. Accordingly, this shows what pages are valid and which pages are invalid. 
Additionally, when the block is erased, the timestamp field will contain all 1's, 
indicating that the block is deleted. 

t. And a flash memory controller, wherein if a write operation is requested for 
the logical block number, the flash memory controller performs one of (a) a first 
write operation which writes the data and the meta-information in a first physical 
block corresponding to the logical block number, if the first write operation has 
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not previously been performed for the logical block number, and changes the 
flash memory state information of the physical block corresponding to the logical 
block number. Paragraph 0055 shows that each page contains overhead data 
49. It is inherent that this data is written to the page when the first write is 
performed for the logical page number, as otherwise the system would be unable 
to tell if later written data is later or earlier. 

u. And (b) a second write operation which writes the data and the meta- 
information in a second physical block, if the first write operation has been 
performed for the logical block with the logical block number, wherein the flash 
memory state information of the physical block corresponding to the logical block 
number is not changed. Paragraph 0049 shows that when new data is to be 
written to a logical block corresponding to physical block PBN 0, item 35 of figure 
8, which is full, a new physical block PBN 1, item 39 of figure 8, is selected and 
the new pages are written to PBN 1 . Paragraph 0055 shows that an individual 
page contains data, item 45 of figure 10, and meta-information, item 49 of figure 
10. Paragraph 0048 shows that when new pages are written to a logical block, 
the pages containing the original data are not tagged. The last sentence of 
paragraph 0047 further emphasizes this by stating "the writing of the old/new or 
other flags, as described with respect to FIGS. 6, 7 A and 7B, cannot be 
tolerated." 

v. Additionally, the Examiner respectfully notes that that claim 18 only 
requires performing one of the first write operation and second operation. 
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1 5. Claim 19 is taught by Conley as: 

w. The apparatus as claimed in claim 18, wherein each physical block 
comprises a main area which stores the data and a spare area which stores the 
meta-information, the logical block number and the flash memory state 
information. Figure 10 shows that each page contains user data area 45 and 
overhead area 49, which includes the LBN 41 and timestamp 43. 

16. Claim 20 is taught by Conley as: 

x. The apparatus as claimed in claim 18, wherein each physical block 
comprises a main area into which the data is written and a spare area into which 
the meta-information is written. Figure 10 shows that each page contains user 
data area 45 and overhead area 49, which includes the LBN 41 and timestamp 
43. 

1 7. Claim 21 is taught by Conley as: 

y. The apparatus as claimed in claim 19, wherein the meta-information is 
written in the spare area simultaneously as the data of the logical block is written 
in the main area. Paragraph 0055 shows that the data 45 and meta-information 
49 are part of the same page. As the data and meta-information are part of the 
same page they would inherently be written simultaneously, as the system of 
Conley writes data on a page basis. 
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Claim Rejections - 35 USC § 103 

18. The following is a quotation of 35 U.S.C. 1 03(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

19. Claims 5-6, 8-10, 15, and 17 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Conley (cited supra) in view of Kim et al. (US 6,381, 176). 

20. Claim 5 is taught by Conley as shown supra with respect to claim 1 . 

21 . Although Conley teaches that blocks having the same logical block number can 
be distinguished by their timestamps, it does not disclose expressly performing a 
recovery operation. 

22. With respect to claim 5, Kim teaches: 

z. The apparatus as claimed in claim 1, wherein the flash memory controller 
is configured to perform a recovery operation which detects, during a scanning 
process, physical blocks for the logical block number and recovers from an error 
by determining a valid block for the logical block among the detected physical 
blocks. Kim teaches at column 6 lines 29-36 that a recovery operation is 
required if two valid blocks having the same logical block number exist. In the 
system disclosed by Conley, paragraph 0050 shows that it can be determined 
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which of multiple pages having the same logical block number and page offset is 
the correct page by comparing the timestamps of the blocks. 

23. At the time of the invention it would have been obvious to one of ordinary skill in 
the art that a recovery operation is necessary in the event of an error during writing. 

24. Conley and Kim are analogous art because they are from the same field of 
endeavor, the design of flash memory systems. 

25. The motivation for doing so would have been to determine which block will be 
erased during a recovery operation (Kim, column 6 lines 30-36) 

26. Therefore, it would have been obvious to combine Kim with Conley for the benefit 
of determining which pages are old and can be deleted to obtain the invention as 
specified in claims 5, 6, and 8-10. 

27. Claim 6 is taught by Conley as: 

aa. The apparatus as claimed in claim 5, wherein the scanning process 
comprises reading a logical block number for each of the physical blocks by 
investigating the flash memory based on a latest accessed block. Paragraph 
0052 shows that when the controller reads the data, it compares the counts in 
fields 43 and 43' of pages having the same LBA and page offset, 
bb. And investigating a field of a block allocation table corresponding to the 
read logical block number. Figure 9, discussed in paragraph 0049, which is 
formed from the data in fields 41 and 41', shows the table that provides a 
mapping from logical blocks to physical blocks. 
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28. Claim 8 is taught by Conley as: 

cc. The apparatus as claimed in claim 5, wherein the recovery operation 
recovers from an error by determining a latest accessed physical block for the 
logical block number among the detected physical blocks according to priorities 
set during the scanning process, as the valid block. Conley paragraph 0050 
shows that the most recently written page is determined by checking field 43, the 
timestamp. 

dd. And rewriting flash memory state information written in other physical 
blocks of the detected physical blocks as deleted. Paragraph 0062 shows that 
updating one or more blocks of data will result in one or more blocks storing the 
data to be superceded by the new data, and the blocks with superceded data are 
identified for erasure. 

29. Claim 9 is taught by Conley and Kim as: 

ee. The apparatus as claimed in claim 5, wherein the recovery operation is 
performed during the initializing the flash memory. Kim column 4 lines 22-25 
shows that when a flash memory is initially used, a logical unit number to 
physical unit number table is provided. To generate such a table in a system 
using the timestamps of Conley, it would be necessary to determine which of the 
pages sharing the same logical block number and page offset is the most recent 
page. 
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30. Claim 10 is taught by Kim as: 

ff. The apparatus as claimed in claim 5, wherein the recovering from the 
error is performed during reclaiming the flash memory wherein the reclaiming 
comprises moving data written in a predetermined unit of the flash memory to a 
new unit. Column 8 line 55 to column 9 line 4 teaches that in a reclaim operation, 
valid blocks and related metadata are copied to a new unit. In order to determine 
which blocks are valid in a system using the timestamps of Conley, the 
timestamps of pages having the same logical block number and page offset must 
be compared. 

31 . Claim 1 5 is taught by Conley as shown supra with respect to claim 1 1 . 

32. Although Conley teaches that blocks having the same logical block number can 
be distinguished by their timestamps, it does not disclose expressly performing a 
recovery operation. 

33. With respect to claim 15, Kim teaches: 

gg. The method as claimed in claim 1 1, further comprising a recovery 
operation comprising detecting, during a scanning process, physical blocks for 
the logical block number and of recovering from an error by determining a valid 
block for the logical block among the detected physical blocks. Kim teaches at 
column 6 lines 29-36 that a recovery operation is required if two valid blocks 
having the same logical block number exist. In the system disclosed by Conley, 
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paragraph 0050 shows that it can be determined which of multiple pages having 
the same logical block number and page offset is the correct page by comparing 
the timestamps of the blocks. 

34. At the time of the invention it would have been obvious to one of ordinary skill in 
the art that a recovery operation is necessary in the event of an error during writing. 

35. Conley and Kim are analogous art because they are from the same field of 
endeavor, the design of flash memory systems. 

36. The motivation for doing so would have been to determine which block will be 
erased during a recovery operation (Kim, column 6 lines 30-36) 

37. Therefore, it would have been obvious to combine Kim with Conley for the benefit 
of determining which pages are old and can be deleted to obtain the invention as 
specified in claims 15 and 17. 

38. Claim 17 is taught by Conley and Kim as: 

hh. The method as claimed in claim 15, wherein the recovering comprises 
recovering from the error by determining a latest data written among data of a 
specific logical block number detected during reclaiming the flash memory and 
wherein the reclaiming comprises moving data written in a predetermined unit of 
the flash memory to a new unit. Conley paragraph 0050 shows that the most 
recently written page is determined by checking field 43, the timestamp. Kim 
column 8 line 55 to column 9 line 4 teaches that in a reclaim operation, valid 
blocks and related metadata are copied to a new unit. In order to determine 
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which blocks are valid in a system using the timestamps of Conley, the 
timestamps of pages having the same logical block number and page offset must 
be compared. 

Allowable Subject Matter 

39. Claims 7, 16, and 22-25 are objected to as being dependent upon a rejected 
base claim, but would be allowable if rewritten in independent form including all of the 
limitations of the base claim and any intervening claims. 

Response to Arguments 

40. Applicant's arguments filed 9/29/2008 have been fully considered but they are 
not persuasive. 

41. First point of Argument 

42. Applicant's arguments with respect to the rejection of claims 2, 12, and 20 under 
35 USC 1 12 first paragraph, see the seventh paragraph on page 9, have been carefully 
and fully considered, and are found persuasive. Accordingly, said rejection has been 
withdrawn. 

43. Second point of Argument 

44. With respect to the rejection of claim 1 under 35 USC 102(b) as being anticipated 

by Conley, see the first and second paragraph beginning on page 1 1 , Applicant argues: 

"Therefore, Conley discloses searching for free pages in the block. If the 
free pages are not found, the data is written into the free pages of another block. 
The logical data is not changed for the old or the new block. Rather, the new data 
is identified by tracking the newest pages. The newest pages are tracked by (1) a 
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time stamp; (2) a counter; (3) a memory location. The controller reads the pages 
from the memory and determines which pages, assigned to the same logical 
address, are new and which are old. 

Conley does not teach or suggest writing meta-information for each page 
which comprises writing an indicator to indicate a state of the physical block as 
valid, deleted or invalid. Conley writes either (1) a time or (2) a counter for each 
page. In contrast, amended claim 1 requires each physical block to be identified 
as valid, invalid or deleted. Further, the writing of the valid indicator is performed 
for the memory state information of the physical block into which the writing is 
being currently performed, without changing the memory state information of the 
old block." 

45. The Examiner respectfully disagrees. As noted by Applicant, Conley teaches 
using a counter to distinguish between the newest page, a valid page, and older 
unerased pages, invalid pages. Conley teaches in paragraph 0055 that the time stamp 
(paragraph 0051 shows that a module N counter can be used in place of the timestamp) 
is written to each page. The Examiner further notes, that when a block is erased, all the 
bits contained within that page are set to 1 . Accordingly, this timestamp field 55 is 
metadata that indicates a state of the physical page as valid, if it is the newest page for 
a given logical block number, invalid, if it is not the newest page for a given block 
number, or deleted, if it is in an erased state. 



Conclusion 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to JARED I. RUTZ whose telephone number is (571)272- 
5535. The examiner can normally be reached on M-F 8:00 AM - 4:30 PM. 
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If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Kevin Ellis can be reached on (571)272-4205. The fax phone number for 
the organization where this application or proceeding is assigned is 571-273-8300. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a 
USPTO Customer Service Representative or access to the automated information 
system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 
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Examiner 
Art Unit 2187 
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